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(54) Method for visualizing locality within an address space 



(57) A method and thai display certain aspects of a 
computer memory on a display screen m accordance 
with a fractal curve. In at least one embodiment, the frac- 
tal curve is a Hilbert curve. The fractal curve display can 



be used as an aid in visualizing various types of infor- 
mation about a computer memory. Certain embodi- 
ments have a display that remains static, while other 
embodiments have a display that is dynamic and chang- 
es in real-time to reflect changes in memory. 
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Description 
BACKGROUND 

[0001] This application relates tocomputers and com- 
puter systems and further relates to a method and ap- 
paratus for visually disolaying various aspects cf mem- 
ory. 

[0002] As computer systems become more complex, 
it is becoming more difficult for human beings to easily 
unaerstanc and grasp all the intricacies involved in any 
given computer system 

[0003] During execution, a computer system may 
move units of memory, such as pages or cache lines 
between units of hardware. As more complex caching 
systems are designed and as caching systems begin to 
have more and more levels, it is becoming more and 
more difficult for human beings :o understand whether 
a given caching system is operating efficiently for the 
software executing on the computer system 
[0004] Software currently exists to aid a human oemg 
in visualizing certain aspects of a computer's memory, 
such as the performance impact of cacning These con- 
ventional software orograms. however, display memory 
using a line-by-line display on a display dev:ce. For ex- 
ample, in sucn a line-by-line display, a pixel representing 
information about a first unit of memory is displayed on 
a first line in a first column of a display screen A pixel 
representing information about a second unit of memory 
is displayed on a first line in a second column of the dis- 
play screen. A pixel representing information about a 
last unit of memory may be displayed on a last line in a 
last coljmn of a display. screen and soon Pixels rep- 
resenting information about intermediate units cf mem- 
ory are disolayed. one after the other on consecutive 
rows and in consecutive columns witnin each row (or 
vice ve'sa .n consecutive columns and rows) 
[0005] The term "locality cf memory" refers to the lo- 
cation of data (eg. variables) within memory in time and 
space Accessing a variable closely in time is called 
"temporal locality " Accessing variables stored physical- 
ly close together is called "spatial locality." Physical lo- 
cations in a memory that are close together have a high 
spatial :ocality. For example, a variable that is reao from 
close together in time has a high temporal locality For 
example, a ^9 ,h memory unit anc a 50 th memory unit 
(such as bus. bytes, words, pages etc.) that are physi- 
cally close to each other in a computer memory have a 
high spatial locality. As another example, if a variable is 
read twice in quick succession. :he variable has a high 
temporal locality. On modern computer systems, tem- 
poral and spatial Iccality impact performance 
[00061 Unfortunately in conventional iine-by-line vis- 
ualization software, even though a 49 th memory unit is 
physically contiguous to a 50 ,h memory unit in the actual 
memory of the computer, it is entirely possible that the 
display pixels corresponding to the memory units will be 
on opposite sides of the display screen For example. 



the pixel corresponding to the 49 ,h memory unit might 
be the last column in tow n. wmle the pixel correspond- 
ing to ;he 50 th memory unit might be displayed in the 
first column of row n+1 Because conventional visuali- 

5 zation :ools do not necessarily show memory units hav- 
ing a high localny as being physically near each other 
cn the display, conventional visualization tools are not 
ideal for aiding a human oemg in visualizing now various 
memory units relate to each other or for visualizing lo- 

io cality 

[0007] Another example cf conventional visualization 
software displays memory accesses by address on one 
axis of a graph and time on the other axis. This method 
also fails to present data in a way that effectively aids 
'5 human understanding of the relationships between the 
aata. 

SUMMARY OF THE INVENTION 

20 [0008] The described embodiments of the present in- 
vention provide a method and apparatus that display 
certain aspects of a computer memory on a display 
screen in accordance with a 'racial curve instead of a 
line-by-line display In at least one embodiment, the frac- 
as tal curve is a Hilbert curve The fractal curve display can 
be used as an aid in visualizing various types of infor- 
mation about a computer memory. Certain embodi- 
ments have a display that remains static, while other 
embodiments have a oisplay that is dynamic and chang- 

30 es in real-time to reflect changes in memory. 

[0009] For example the display can be used as an 
aid to visualize memory access patterns, such as when 
and/or where read or write operations occur in a com- 
puter memory As a second example, the display can be 

ss used as an aid :o visualize wmch pages are currently 
being swapped in or cut of various levels of memory in 
a virtual memory system As a third example the display 
can be used as an aid to visualize which cache lines are 
active m a caching system As a fourth example, the dis- 

-o play can be used as an atd to visualize which oages are 
being swapped into memory As a fifth example the dis- 
play can be used as an aid to visualize the read/write 
permissions of various pages of memory As a sixth ex- 
ample, the display can be used as an aid tc visualize 

J 5 the shared/modified exclusive states of cache lines. 
[0010] . Use of a Hilbert curve as an aid in visualizing 
memory has the advantage that it allows memory 
groups equal to powers of two to be displayed near each 
other. Fcr example, display oi:s of the fractal curve cor- 

^o responding to memory addresses OOxxxxxx. where xx 
is any value, are grouped *n a same quadrant of the 
memory disolay. Similarly, display bits cf the fractal 
curve corresponding to memory address OOOOxxxx are 
grouped within a sub-quadrant of the quadrant holding 

55 oisplay bits for the addresses OOxxxxxx. Display bits of 
the fractal curve corresponcmg to memory address 
OOOOOOxx are groupea within a suo-sub-quadrant of the 
quadrant holding display bus for the addresses 
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OOCOxxxx. and so on. 

[0011] Certain embodiments use color on the display 
to indicate types of memory access, while other use dis- 
play color to indicate a type of memory being represent- 
ed in the display, in addition, certain embodiments of the 
present invention also use a 3-D version of a fractal 
curve, either drawn in 2D or rendered in 3D to aid ;n 
visualization of various aspects of memory. In accord- 
ance with the purpose of the invention, as embodied ard 
broadly described herein the invention relates to a 
method of displaying information, performed by a data 
processing system, comprising the steps of receiving 
notification of a memory event, including a memory lo- 
cation: determining a portion of a fractal curve that cor- 
responds to the memory location at which tne memory 
event has occurred: and highlighting a portion of a dis- 
play screen in accordance with the determined portion 
of the fractal curve. 

[0012] A fuller understanding of the invention will be- 
come apparent and appreciated by referring to the fol- 
lowing description and claims ta*en in conjunction with 
the accompanying drawings 

BRIEF DESCRIPTION OF THE DRAWINGS 

[0013] The accompanying drawings whicn are incor- 
porated in ard constitute a part of this specification, il- 
lustrate several embodiments of tne invention and. to- 
gether with the description, serve to explain the princi- 
ples of the invention. 

[0014] Fig. 1 is a block diagram of a computer system 
in accordance with one embodiment of the present in- 
vention. 

[001 S] Fig. 2 shews an illustration of a curve used by 
a computer program of Fig. 1 as an aid to visualizing 
certain aspects of a computer memory of Fig. 1 
[0016] Fig. 3 is a block diagram showing an overview 
of steps performec by an embodiment of the invention 
to map portions of memory onto a fractal curve 
[0017] Fig. 4 is a flow chart showing sieps performed 
by an embodiment of the present invention to map por- 
tions of memory onto a fractal curve 
[0018] Fip,. 5 shows a state table used by tne flow 
chart of Fig. 4 to determine which portion o: the fractal 
curve corresponds to a particular portion of memory. 
[0019] Fig. 6 shows possible rotation values for the 
state table of Fig. 5. 

[0020] Fig. 7 shows an example of levels of quacrants 
used in the flow chart of Fig. 4. 

[0021] Figs. 8 and 9 provide an example showing how 
to locate a portion of a displayeo fractal curve corre- 
sponding to a memory address. 
[0022] Figs. 10(a) and 10(b) provide examples of 
three-dimensional fractal curves shown on a two-dimen- 
sional display. 



DETAILED DESCRIPTION OF PREFERRED 
EMBODIMENTS 

I. General Discussion 

5 

[0023] Fig 1 is a block diagram of a data processing 
system 100 in accordance with a preferred embodiment 
cf the present invention. In Fig. 1. data orocessing sys- 
tem 1C0 includes a processor 102 and a data storage 
'0 area (eg a memory) 104 The example of Fig 1 shows 
that processor 102 contains an exemplary cache 111. 
although not ail systems on which the present invention 
is implemented contain a cache and not all caches in 
such systems are necessarily located in processor 1C2. 
'5 Data storage area 104 includes certain well-known 
types of data, such as data structures, pages, page ta- 
bles, etc 106. Storage area 104 also includes memory 
visualization software 1 10. which aids in visualization of 
various aspects of the computer system, as described 
20 below in detail. Memory visualization software 1 10 could 
also be located in a computer system different from sys- 
tem 100. such as a remote system (not shown). Storage 
area 104 preferably also includes software (not shown) 
for communicating with a network, such as a LAN. WAN. 
25 cr the internet, although the invention also can be im- 
plemented on standalone computers. 
[0024] System 100 preferably includes an input de- 
vice 112. such as a keyboard pointing device, mouse, 
louchpad. etc.. which allows input to be read by proces- 
30 sor 102. System 100 preferably also includes an output 
device 140. This output device can be. for example, a 
computer monitor, a display cevice. or any device that 
allows processor 102 to send or display output. 
[0025] A person of ordinary skill in the art will under- 
35 stand that system 100 may also contain additional ele- 
ments, such as mout/output hnes: input devices, such 
as a keyooard. a mouse, and a voice input device: ana 
cisplay devices such as a display terminal System 100 
may also mciude a computer readable input device 1 50. 
-o such as a floppy disk drive CD ROM reader, or DVD 
reader, that reads computer instructions stored on a 
computer readable medium 160. such as a floppy disk, 
a CD POM. or a DVDcisk. System 100 also may include 
application programs, operating systems, data etc.. 
j s which are not shown in the figure for the sake of clarity. 
It also will be understood that system 10 can also include 
numerous elements not shown, sucn as disk drives, 
keyboards, display devices, network connections, addi- 
tional memory, additional processors or CPUs. LANs. 
50 mput/output lines, etc. 

[0026] In the following discussion, it will be under- 
stood that the steps of methods and flow charts herein 
discussed herein preferably are performed by processor 
102 (or another appropriate processor) executing m- 
55 structions stored in storage area 104 (or other appropri- 
ate memorres or storage areas). It will also oe under- 
stood that the invention is not limitea to any particular 
implementation or programming technique and that the 
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invention may be implemented using any appropriate 
techniques for implementing the functionality described 
herein. The invention is not limited to any particular pro- 
gramming language or operating system. 
[0027] The instructions m storage area 104 may be 
road into storage area 104 from the ccmputcr-rcadabto 
medium 160 Execution of sequences of instructions 
contained in mam memory causes one of the proces- 
sors to perform the process steps described herein In 
alternative embodiments hard-wired circuitry may be 
used in place of or in combination with software instruc- 
tions to implement the invention. "Hius. embodiment of 
the invention are not limited to any specific combination 
of hardware circuitry and software. 
[0028] The term "computer-readable medium" as 
used herein refers to any medium that participates n 
providing instructions to a processor for execution. Such 
a medium may take many forms, deluding out not lim- 
it ec to. non-volatile media, volatile media, and transmis- 
sion media. Non-volatile media includes, for example, 
optical or magnetic disks, such as a storage device. Vol- 
atile media includes dynamic memory Transmission 
media include coaxial cables, copper wire and fiber op- 
tics, including the wires that comprise a bus within a 
computer. Transmission media can also take the form 
ol acoustic or light waves, such as those generated dur- 
ing radio-wave and infra-red data communications 
[0029] Common forms of computer-readable media 
include, for example a floppy disk, a flexible disk a hard 
disk, magnetic tape, or any other magnetic medium, a 
CD-ROM. any other optical medium, punchcaras. pap- 
ertapes. any other physical medium with patterns of 
holes, a RAM. a PFOM. an EPROM. a FLASH-EPROM. 
any other memory chip or cartridge, a carrier wave, or 
any other medium from which a computer can read. 
[0030] Various forms of computer readable media 
may be involved in carrying one or more sequences of 
one or more instructions to a processor for execution 
For example, the instructions may initially be carried on 
a magnetic disk of a remote computer. The remote com- 
puter can load the instructions into its dynamic memory 
anc send the instructions over a telephone line using a 
modem A modem local to the computer system can re- 
ceive the data on the telephone line and use an infra- 
red transmitter to convert the data -o an inf ra-rea signal. 
An infra-red detector coupled to a bus can receive the 
data earned in the infra-red signal and olace the data on 
the bus. The bus carries data io main memory, from 
which a processor retrieves and executes the 'nstruc- 
tions. The instructions received by main memory may 
optionally be stored on a storage device either before 
or after execution by a processor 

II Visualization of Memory 

[0031] Fig. 2 shows a curve 200 used by a ccmputer 
program of Fig. 1 as an aid to visualizing certain aspects 
of a computer memory of Fig. 1 in the described em- 



bodiment, the curve is not drawn explicitly Instead. 

memory addresses of. for example, storage area 104 or 

cache 111 . are mapped onto tne curve. Curve 200 can. 

in fact, corresponc to any appropriate memory, whether 
5 in the ccmputer 1 00 or a secondary storage 120. The 

aisplay includes a fractal curve (such as a Hilbcrt curve). 

where each edge of the curve represents an associatea 

portion or aspect of the memory. As explained below in 

more cetail. use of a fractal curve to represent portions 
*o of or aspects of a memory allows a human being to more 

easily visualize relationships between the portions of 

memory. 

[0032] Specifically, the use of a Hilbert curve allows 
each cuadrant and subquadrant of the curve to corre- 

'5 spond to respective bits of a memory address. The na- 
ture of a Hilbert curve allows easy visualization of the 
locality of memory/hardware, since addresses that re- 
side on even powers of two map into quadrants and sub- 
cuadrants ol the fractal curve. Rectangular regions of 

-0 the curve of a given size naturally correspond to hard- 
ware entities, such as cache lines or pages, so it is easy 
for a human being to see hew memory access patterns 
map onto hardware. Portions of the display that are vis- 
ually nested correspond to units of hardware that are 

25 logically nested. For example, in Fig. 2. curve 200 is 
used to aid in visualizing a ten bit address. Fig. 2 shows 
a portion 250 of curve 200 that corresponds to locations 
identified by a page (which has 256 locations). As a fur- 
ther example. Fig. 2 shows a smaller poition 252 of 

oo curve 200. nested within portion 250. that corresoonds 
to a cache line (which has 32 locations.. 
[0033] Fig 3 is a block diagram shewing an overview 
cf steps performed by an embodiment of the invention 
to map portions of memory onto a fractal curve. In the 

-'5 cescribed embodiment, the fractal curve is not drawn 
explicitly 

[0034] The steps of ng. 3 can be performed by mem- 
cry visualization software r.O being executed by proc- 
essor 102 As shown, in 5tep301 . software 110 receives 

-o notification of a memory event at a certain address. A 
memory event can be. lor example, a memory access 
such as a read or write or a cache access A memory 
event can also be the simple receipt cf a next one of 
sequential memory addresses if the software 110 is to 

J 5 map' all addresses in a memory onto the curve. In the 
cescribed embodiment, notification of a memory event 
is received from the operating system of the data 
processing system, although notification of a memory 
event can be received from any approonate source. For 

so example, the Solaris operating system available from 
Sun Microsystems. Inc. allows executing programs tc 
request that the operating system notify them of certain 
memory events. (Solans is a trademark or registerea 
trademark of Sun Microsystems. Inc. in the United 

55 States and ether countries. ) As another example, other 
operating systems may allow the software 110 to poll 
the operating systems for the occurrence of memory 
events. 
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[0035] Steo 302 determines a position on the fractal 
curve in acccraance with the received memory address 
bits. Details of step 302 are shown in more oetail in Fig. 
4. Step 304 hignlights the portion of the fractal curve 
corresponcing to the received memory address. This 
portion can be a single pixel or a group of pixels, do- 
pending on the resolution of the particular implementa- 
tion of the invention. Thus, for example, if software 110 
is designee tc Highlight a portion of the curve whenever 
a read access occurs every read access oi a new ad- 
dress will higniight another pixel on the curve 
[0036] Fig 4 is a flow chart showing steps performed 
by an embodiment of the present invention to generate 
a fractal curve display, where the display indicates the 
localities of memory accesses. The flow chart shows de- 
tails of step 3G2 and 304 of Fig. 3 Step 401 displays a 
fractal curve on the display. As discussed above, certain 
embodiments may not perform this initial step. 
[0037] in step 4C2. software 110 receives notification 
of the occurrence of a memory event at a memory ad- 
dress and. n step 404. chooses a color to reoresent the 
event. In some embodiments, all memory events are in- 
dicated by a sing-e color. In other embodiments, various 
types of memory events are indicated by different re- 
spective colors For example, read accesses may be 
displayed in a first color, while write accesses may be 
displayed in a second color. As another example, all 
memory locations having a read permission may be dis- 
played in a first color, while all memory locations having 
a read/write permission may be displayed in a second 
color. As a :hira example, all memory locations ac- 
cessed a cer:am number of times per time unit may be 
displayed in a first color, while all memory locations ac- 
cessed a different numoor of times per time unit may bo 
displayed in a second color. As a fourth example, all 
memory locations filled from a cache may be displayed 
in a first color while all memory locations filled from sec- 
ondary storage may be displayed m a second color As 
a fifth examcie all memory locations in a cache that 
have been written back tc secondary storage may be 
displayed in a first color, while all memory locations that 
have not been witten oack may be displayed in a sec- 
ond color. 

[0038] Other variations using more than two colors 
will be apparent As a sixth example, all memory loca- 
tions having a shared, modified, cr exclusive state are 
displayed in respective colors. 

[0039] Steps 406 througn 414 form a loop that deter- 
mines which portion of the fractal curve corresponds to 
the received memory address. This loop preferably is 
repeated for eacn two bits of the received address. In 
step 4C6. an initial "rotation" is set to a value of "I" as 
described beiow in connection with Fig. 6. An initial ro- 
tation of "I" is cnosen because, in the example, the 
Hilbert curve is initially oriented in this rotation. Other 
initial orientations are possible. 
[0040] Step 403 gets the next two bits of the received 
address. In step 41 0. software HO uses the rotation and 



the two bits of the memory address to irdex into a stale 
table 1 1 4 shown in Figs 1 and 5 to yield a "next rotation" 
value and new x.y values. These x.y values are saved 
for each iteration of the loop until an x.y value has been 
s saved for each two bits of the received address. At this 
point, in step 416. software 110 highlights a portion of 
the fractal curve. :n the chosen color, at a position on 
the curve represented by the saved sequence of x and 
y values The saved x values can be concatenated to 
10 form the x position of the position on the curve The 
saved y values can be concatenated to form the y posi- 
tion of the position on the curve. Further details of step 
416 are shown by the examples below 
[0041 ] Fig. 5 shows an example of the state table 1 1 4 

'5 used by [he flow cnart of Fig. 4 to determine which por- 
tion of a fractal curve corresponds to a particular portion 
cf memory. The state table 1 1 4 in the described embod- 
iment includes input values: a current rotation value ana 
two address bits: and output values: two x.y oits and a 

?o next rotation value. As discussed above, each two bits 
cf a memory address along with a current rotation value 
are usee to determine output x y values and a next ro- 
tation vaiue. The sequence of x.y values are saved and 
used to highlight a portion of the fractal curve corre- 

25 spondmg to the memory address. 

[0042] Fig 6 shows possible rotation values for the 
state table 114 of Fig. 5. A rotation value refers to the 
order of two bit values in a quadrant used tc draw the 
fractal curve. For example, the "L" rotation value refers 
to an order 602 in which the two bit vaiues 00. 01 . 10. 
and 1 1 form a counterclockwise path, starting at a lower 
left quadrant. The "FT rotation vaiue refers to an order 
604 in wnich the two bit values 00. 01. 10. and 11 form 
a counterclockwise path, starting at an upper right quad- 

3S rant. The other rotation values "LP "D". V V "u u . ana 
"d" are similarly shown. 

[0043] Fig 7 shows an example of levels 702. 704. 
706 and 708 of quadrants used in the flow chart of F:g. 
4 At a first level 702. the space in which :he fractal curve 

-o is to be drawn in diviced into four quacran?s Since, in 
the Figure, the rotation is ":" the quacrants are num- 
bered clockwise from the too =eft as 00. 01. 13. and 11 
As further shown, each quadrant in level 1 is broken into 
four level 2 sub-quadrants, each also numbered 00. G1 . 

-5 10. and 1 1 . the order of which depends on the rotation 
value associated with each sub-quadrant. As further 
shown each sub-quadrant in level 2 is oroken into four 
level 3 sub-sub-quadrants, each also numbered 00. 01 . 
10. and 11. the order of which depends on the rotation 

50 value associated with each sub-sub-quadrant. As fur- 
ther shown, each sub-sub-quadrant in level 3 is broken 
into four level 4 sub-sub-sub-quadrants, each also num- 
bered 00. 01. 10 and n the order of which depends on 
the rotation value associated with each sub-sub-sub- 

55 auadrant. 

[0044] Thus, in the example of Fig. 7. each level 4 
sub-sub-sub-quadrant corresponds to one eight-bit 
memory address. Given an initial rotation and initial two 
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address bus. a state table similar to ihe siaie table of 
Fig. 5 can be used to determine which portion of the frac- 
tal curve lie., which suo-sub-sub quadrant) corre- 
sponds to a given memory address. Note that the mem- 
ory adcress can represent a single bit. a byte, a word. $ 
a cache lino, a pace, or any other appropriate memory 
unit. 

[0045] It .vill be understood that the example of Fig. 7 
is provided by way of example and that other fractal 
curves can have other organizations and that different ?o 
lengths of memcry addresses will have different num- 
bers of levels of subquadrants. Fcr example, a sixteen 
bit address where each edge of a level of the curve rep- 
resents two address bits will have eight levels. 
[0046] Figs. 6 and 9 provide an example showing how 
to locale a portion of a displayec fractal curve corre- 
sponding to a memory address In the example, soft- 
ware n0 determines a portion of a fractal curve corre- 
sponding to a memory address 10001110. Because the 
address has eight bits, four x.y pairs are determined ard 
saved in one embodiment, a level N storage 130 ( n ac- 
cordance witn the state taole of Fig. 5. Specifically, as 
shown n Fig. 5. an initial rotation cf "I" and initial two bit 
address values of 10 result in next rotation values of I 
U. r. and r and further result in x.y pairs of 11. 00. 10. «?5 
and 00. 

[0047] As shown in the example of Fig. 9. the saved 
x.y pairs identify a portion 902 of the fractal curve. Spe- 
cifically m the example, the first rotation value "I" and 
the first two address bits 1 0 identify a bottom right quad- * w 
rant in the first level. The second rotation value "I" and 
the second two address bits 00. identify a too left quad- 
rant in the second level The third rotation value 'LI" and 
the third two address bits 1 1 identify a top ngnt quadrant 
in the third level The fourth rotation value "r" and the 35 
fourth x.y pair 1 0 ident.fy a top left quadrant in the fourth 
level The top left auadrant ;s the curve portion 902 at 
position (10 9) wnich can be a single pixel or multiple 
pixels and which corresponds to the received memory 
adcress. ~° 
[0048] Figs. 1 G- a) shows an example of a ; irst level of 
a three-dimensional fractal curve Fig 10(b) shows an 
example of a two connected three-dimensional fractal 
curves. This curve can be displayed to any desired 
depth cf leve;s and in either two dimensions or three ci- -5 
mensions (given a proper display device), as is known 
by persons of ordinary skill in the art. As wnl be appre- 
ciated by persons of ordinary skill in the art. a portion of 
a three-dimensional curve corresponding tc a memory 
address can be determined using a state table similar $o 
to that of F ; g. 5. 

[0049] In summary, the present invention displays 
memory locations in accordance with a fractal curve, 
such as a Hiiben curve. Use of a fractal curve tc map 
memory locations causes locations having a similar lo- 55 
cality to be oisplayed near each other, thus imorovmg 
the ability of a human being to visually appreciate the 
locality of memory events. 



[0050] While the invention has been described in con- 
junction with a specific embodiment, it is evident that 
many alternatives, modifications and variations will be 
apparent to those skilled in the art in light of the forego- 
ing description. For example, the entire display can be 
updated at encc. instead of pixel by pixel. Accordingly, 
it is intended to embrace ail such alternatives, modifica- 
tions and variations as fall within the spirit and scope of 
the appended claims and equivalents. 

Claims 

1 A metnod o! displaying information, performed by 
a data processing system, comprising the steps of: 

receiving notification of a memory event, in- 
cluding a memory location: 

determining a portion of a fractal curve that cor- 
responcs to the memory location at which the 
memory event has occurred 

Highlighting a portion of a disolay screen in ac- 
cordance with the determmec portion of the 
'racial curve: and 

displaying the fractal curve on the display 
screen 

3. The method of claim 1 wherein the fractal cun/e 
is a Hilbert fractal curve. 

4 The method of claim 1 whorom the memory lo- 
cation is a memory location that has eit.ner a READ 
permission or a READ/WRITE permission 

5 The method of claim 1 therein tne memcry 
event either reacs from the memory location or 
writes tc the memory location. 

6 The method of claim 1 wherein the memory lo- 
cation has been accessed at least at a predeter- 
mined frequency. 

7 The method of claim 1 wherein the memory lo- 
cation is a location in a cache memory that has been 
filled from another memory or that has been written 
back to another memory, and wherein the memcry 
location has one of a shared, modified and exclu- 
sive state. 

6. The method of claim 1 . wherein the fractal cun/e 
is a three-dimensional fractal cun/e displayed in at 
least two dimensions, wnerem a plurality of portions 
of the display screen corresponding to the fractal 
curve are highlighted at once. 
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9 T he method of claim 1 . wherein ire display is dy- 
namic and changes as corresponding mernoiy 
events occur. 

1 0. The method of claim 1 wherein the determining 5 
stop includes (ho step ol determining a oortion of a 
fractal curve in accordance with a state tabie 
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